Case example Raw Data
Table
Data Preparation
There are 2 raw data available on the Github website, including “POC”
file and “PhillyCrimeSince2015” file. For “POC” file, we will select
random sample of 500 elements in a subset of the data set. In addition,
“PhillyCrimeSince2015” file will only select crime cases in 2023.
Moreover, if the latitude and longitude of the subdataset are missing,
the observation will be excluded.
# read final file
POC = read.csv("https://raw.githubusercontent.com/GUANTSERN-KUO/webcv/main/w07/POC.csv")
set.seed(123458)
#select random sample of 500 elements with NO replacement
kept_samp <- sample(1:nrow(POC), size = 500, replace = FALSE)
#select random sample of 500 rows from data frame
rand500_POC <- POC[kept_samp, ]
# write final data to csv file
write.csv(x = rand500_POC, file = "rand500_POC.csv", row.names = FALSE)
# read final file
Philly = read.csv("https://raw.githubusercontent.com/GUANTSERN-KUO/webcv/main/w07/PhillyCrimeSince2015.csv")
Philly$year <- year(as.POSIXct(Philly$date, format = "%m/%d/%Y %H:%M", tz = "EST") )
Philly2023 <- filter(Philly,year==2023) # create 2023data
Philly2023 <- filter(Philly2023,!is.na(lat)) # remove missing obs
Philly2023$ageColor<-gsub("Fatal","orange",as.character(Philly2023$fatal))
Philly2023$ageColor<-gsub("Nonfatal","darkred",as.character(Philly2023$ageColor))
PhDT <- Philly2023 %>%
dplyr::select(race, age,lng,lat,year)
POCDT <- rand500_POC %>%
dplyr::select(STATE ,county,ADDRESS,ZIPnew,diesel,dist.to.poc,ycoord,xcoord)
Descriptive Study
Purpose & Variables Relationship
The study primary focus on the distribution of diesel used in gas
station. Secondary understanding of the Mean distance between a gas
station and the Point of Compromised in PA. Finally, We want to
understand crime map in PA.
The below is the sub-data table for “PhillyCrimeSince2015”. However,
we will only use 5 variables and display data table as below.
- lng : longitude
- lat : latitude
The average age of offenders was 30.98, with the lowest age of
offenders being 2.
summary(PhDT$age)
Min. 1st Qu. Median Mean 3rd Qu. Max. NA's
2.00 21.00 29.00 30.98 37.00 87.00 23
The below is the sub-data table for “POC”. However, we will only use
8 variables and display data table as below.
- xcoord : longitude
- ycoord : latitude
- dist.to.poc : distance between a gas station and the nearest
POC
The average distance was 17.6, with the lowest distance being 0.12
and maximum distance being 47.7.
summary(POCDT$dist.to.poc)
Min. 1st Qu. Median Mean 3rd Qu. Max.
0.1292 5.6552 12.9125 17.6680 28.8643 47.7133
Distribution of
diesel used in gas station across U.S.
500 gas stations across U.S have been randomly selected from POC
data. 294 gas stations provide Diesel service, that is 58.8 percent of
selected gas stations. While 206 gas stations (41.2 percent) do not have
Diesel service.
piedata <- filter(rand500_POC,!is.na(diesel))
piedataf = data.frame(cate =as.vector(unique(piedata$diesel)),
freq = as.vector(table(piedata$diesel)))
## remove string X
piedataf$cate<-gsub("Y","Yes",as.character(piedataf$cate))
piedataf$cate<-gsub("N","No",as.character(piedataf$cate))
# define a color vector
colors <- c('rgb(211,94,96)', 'rgb(128,133,133)', 'rgb(144,103,167)')
# make a pie chart
plot_ly(piedataf,
labels = ~cate,
values = ~freq,
type = 'pie',
textposition = 'inside',
textinfo = 'label + percent',
insidetextfont = list(color = '#FFFFFF'),
#hoverinfo = 'text',
marker = list(colors = colors,
line = list(color = '#FFFFFF', width = 1)),
#The 'pull' attribute can also be used to create space between the sectors
showlegend = TRUE) %>%
layout(title = 'Distribution of diesel used in gas station',
xaxis = list(showgrid = FALSE, zeroline = FALSE,
showticklabels = FALSE),
yaxis = list(showgrid = FALSE, zeroline = FALSE,
showticklabels = FALSE),
## margin of the plot
margin = list(
b = 50,
l = 100,
t = 120,
r = 50
))
The diesel service of
gas stations throughout the U.S
Looking at a the entire U.S. map, the supply of diesel fuel stations
in each region is fairly normal regardless east region, west region, and
central region. It is convenience for people to find diesel fuel
stations as there are plenty of gas stations within each county and
within short distance.
label.msg <- paste(paste("DIESEL:",rand500_POC$diesel),"\n")
# making static leaflet map
map0 <- leaflet(rand500_POC) %>%
addTiles() %>%
setView(lng=mean(rand500_POC$xcoord), lat=mean(rand500_POC$ycoord), zoom = 14) %>%
addRectangles(
lng1 = min(rand500_POC$xcoord), lat1 = min(rand500_POC$ycoord),
lng2 = max(rand500_POC$xcoord), lat2 = max(rand500_POC$ycoord),
#fillOpacity = 0.2,
fillColor = "transparent"
) %>%
fitBounds(
lng1 = min(rand500_POC$xcoord), lat1 = min(rand500_POC$ycoord),
lng2 = max(rand500_POC$xcoord), lat2 = max(rand500_POC$ycoord) ) %>%
addMarkers(~xcoord, ~ycoord, label = ~label.msg,
popup = ~paste(label.msg,
"<br>state:", STATE,
"<br>county:", county,
"<br>address", ADDRESS,
"<br>zip code", ZIPnew)
)
title <- tags$div( HTML('<font color = "darkred" size =4><b>Do gas stations have diesel service throughout the U.S.?</b></font>')
)
title2 <- tags$div( HTML('<font color = "red" size =0.5><b>500 randomly selected gas stations from the entire gas station dataset</b></font>')
)
###
map0 <- map0 %>%
addControl(title, position = "topright")
map0 <- map0 %>%
addControl(title2, position = "topright")
map0
The Mean distance
between a gas station and the Point of Compromised in PA 2023
Berks county has the highest mean distance (36.52) between a gas
station and the Point of Compromised. Lehigh county has the lowest mean
distance (7.27). The mean difference (29.25) between these two counties
is pretty high.
PA_POC <- filter(rand500_POC,STATE == "PA") # create 2015data
# Specify data frame
group_mean <- PA_POC %>%
# Specify group indicator, column, function
group_by(county) %>%
# Calculate the mean of the "Frequency" column for each group
summarise_at(vars(dist.to.poc),
list(Mean_Frequency = mean))
plot_ly(
data = group_mean,
x = ~county, # Horizontal axis
y = ~Mean_Frequency, # Vertical axis
color = ~factor(county), # must be a numeric factor
#text = ~Species,
# Show the species in the hover text
## using the following hovertemplate() to add the information of the
## Two numerical variables to the hover text.
### Use the following hover template to display more information
alpha = 0.6,
type = "scatter",
mode = "markers",
## graphic size
width = 700,
height = 500
)%>%
layout(
### Title
title =list(text = "Mean distance between a gas station and the nearest POC in PA 2023",
font = list(family = "Times New Roman", # HTML font family
size = 18,
color = "red")),
### legend
legend = list(title = list(text = 'county',
font = list(family = "Courier New",
size = 14,
color = "green")),
bgcolor = "ivory",
bordercolor = "navy",
groupclick = "togglegroup", # one of "toggleitem" AND "togglegroup".
orientation = "v" # Sets the orientation of the legend.
),
## margin of the plot
margin = list(
b = 100,
l = 100,
t = 100,
r = 50
),
## Background
plot_bgcolor ='#f7f7f7',
## Axes labels
xaxis = list(
title=list(text = 'County',
font = list(family = 'Arial')),
zerolinecolor = 'red',
zerolinewidth = 2,
gridcolor = 'white'),
yaxis = list(
title=list(text = 'Mean distance',
font = list(family = 'Arial')),
zerolinecolor = 'purple',
zerolinewidth = 2,
gridcolor = 'white')
)
Crime Map in PA
2023
Below crime map is showing the offenders in PA state in year 2023.
The amount of Non-fatal cases are higher than the amount of Fatal
cases.
ageColor <- Philly2023$ageColor
label.msg <- paste(paste("Race:", Philly2023$race),
paste("\n Age:",Philly2023$age),"\n")
#labels = cat(label.msg)
# making leaflet map
#labels = cat(label.msg)
# making leaflet map
# making leaflet map
map <- leaflet(Philly2023) %>%
addTiles() %>%
setView(lng=mean(Philly2023$lng), lat=mean(Philly2023$lat), zoom = 15) %>%
#OpenStreetMap, Stamen, Esri and OpenWeatherMap.
#addProviderTiles("Esri.WorldGrayCanvas") %>%
addProviderTiles(providers$Esri.WorldGrayCanvas) %>%
addCircleMarkers(
~lng,
~lat,
color = ageColor,
radius = ~ (Philly2023$age/10),
stroke = FALSE,
fillOpacity = 0.4,
label = ~label.msg) %>%
addLegend(position = "bottomright",
colors = c("orange","darkred"),
labels= c( "Fatal", "Nonfatal"),
title= "Crime Category",
opacity = 0.4)
title <- tags$div( HTML('<font color = "darkred" size =4><b>Pennsylvania crime map in 2023 </b></font>')
)
title2 <- tags$div( HTML('<font color = "red" size =0.5><b>The point size is proportional to the age of the criminal </b></font>')
)
###
EnhancedMap <- map %>%
addControl(title, position = "topright")
EnhancedMap <- EnhancedMap %>%
addControl(title2, position = "topright")
EnhancedMap
---
title: "Map Visulation"
author: "Guan Tsern Kuo"
date: "West Chester University"
output:
  html_document: 
    toc: yes
    toc_float: yes
    number_sections: yes
    toc_collapsed: yes
    code_folding: hide
    code_download: yes
    smooth_scroll: true
    theme: lumen
editor_options:
  chunk_output_type: inline
---


<style type="text/css">

/* Table of content - navigation */
div#TOC li {
    list-style:none;
    background-color:lightgray;
    background-image:none;
    background-repeat:none;
    background-position:0;
    font-family: Arial, Helvetica, sans-serif;
    color: #780c0c;
}


/* Title fonts */
h1.title {
  font-size: 24px;
  color: darkblue;
  text-align: center;
  font-family: Arial, Helvetica, sans-serif;
  font-variant-caps: normal;
}
h4.author { 
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  color: navy;
  text-align: center;
}
h4.date { 
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  color: darkblue;
  text-align: center;
}

/* Section headers */
h1 {
    font-size: 22px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

h2 {
    font-size: 18px;
    font-family: "Times New Roman", Times, serif;
    color: navy;
    text-align: left;
}

h3 { 
    font-size: 15px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

h4 {
    font-size: 18px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

/* Decoration of hyperlinks  */

/* unvisited link */
a:link {
  color: green;
}

/* visited link */
a:visited {
  color: purple;
}

/* mouse over link */
a:hover {
  color: red;
}

/* selected link */
a:active {
  color: yellow;
}
</style>

```{r setup, include=FALSE}
# code chunk specifies whether the R code, warnings, and output 
# will be included in the output files.
if (!require("tidyverse")) {
    install.packages("tidyverse")              
    library("tidyverse")
}

if (!require("dplyr")) {
    install.packages("dplyr")              
    library("dplyr")
}
if (!require("lubridate")) {
    install.packages("lubridate")              
    library("lubridate")
}
if (!require("gplots")) {
    install.packages("gplots")              
    library("gplots")
}
if (!require("leaflet")) {
    install.packages("leaflet")              
    library("leaflet")
}
if (!require("maps")) {
    install.packages("maps")              
    library("maps")
}
if (!require("htmltools")) {
    install.packages("htmltools")              
    library("htmltools")
}
if (!require("htmlwidgets")) {
    install.packages("htmlwidgets")              
    library("htmlwidgets")
}
if (!require("leaflegend")) {
    install.packages("leaflegend")              
    library("leaflegend")
}
if (!require("geojsonio")) {
    install.packages("geojsonio")              
    library("geojsonio")
}


if (!require("gapminder")) {
   install.packages("gapminder")
   library(gapminder)
}
if (!require("tidyr")) {
   install.packages("tidyr")
   library(tidyr)
}
if (!require("tidyverse")) {
   install.packages("tidyverse")
   library(tidyverse)
}
if (!require("knitr")) {
   install.packages("knitr")
   library(knitr)
}
if (!require("cowplot")) {
   install.packages("cowplot")
   library(cowplot)
}
if (!require("latex2exp")) {
   install.packages("latex2exp")
   library(latex2exp)
}
if (!require("plotly")) {
   install.packages("plotly")
   library(plotly)
}
if (!require("gapminder")) {
   install.packages("gapminder")
   library(gapminder)
}
if (!require("png")) {
    install.packages("png")             # Install png package
    library("png")
}
if (!require("RCurl")) {
    install.packages("RCurl")             # Install RCurl package
    library("RCurl")
}
if (!require("colourpicker")) {
    install.packages("colourpicker")              
    library("colourpicker")
}
if (!require("gganimate")) {
    install.packages("gganimate")              
    library("gganimate")
}
if (!require("gifski")) {
    install.packages("gifski")              
    library("gifski")
}
if (!require("magick")) {
    install.packages("magick")              
    library("magick")
}
if (!require("grDevices")) {
    install.packages("grDevices")              
    library("grDevices")
}
if (!require("jpeg")) {
    install.packages("jpeg")              
    library("jpeg")
}
if (!require("VGAM")) {
    install.packages("VGAM")              
    library("VGAM")
}
if (!require("MASS")) {
    install.packages("MASS")              
    library("MASS")
}
if (!require("nnet")) {
    install.packages("nnet")              
    library("nnet")
}
if (!require("cluster")) {
    install.packages("cluster")              
    library("cluster")
}
if (!require("dplyr")) {
    install.packages("dplyr")              
    library("dplyr")
}
if (!require("odbc")) {
   install.packages("odbc")
   library(odbc)
}
if (!require("DBI")) {
   install.packages("DBI")
   library(DBI)
}
if (!require("RSQLite")) {
   install.packages("RSQLite")
   library(RSQLite)
}

if (!require("tidyverse")) {
   install.packages("tidyverse")
   library(tidyverse)
}
if (!require("data.table")) {
   install.packages("data.table")
   library(data.table)
}


# knitr::opts_knit$set(root.dir = "C:\\STA490\\w05")
knitr::opts_chunk$set(echo = TRUE,       
                      warning = FALSE,   
                      result = TRUE,   
                      message = FALSE,
                      comment = NA)

db <- dbConnect(RSQLite::SQLite(), dbname = "sql.sqlite")
knitr::opts_chunk$set(connection = "db")


```


# Introduction 

In order to properly design a map data visualization, it is important to understand some general visualization theory: variable data types. Variable data types determine the different visualization encodings that can be used for the data. We will introduce scatter map with a practical example.



# Scatter maps

Scatter maps use discrete markers to represent the geographic location of the data and require latitude and longitude coordinates to be generated. When viewing the table, you will notice that it contains four pieces of geographic information: city, state, latitude, and longitude.


```{r ,echo = FALSE}
knitr:: include_graphics("pic.gif")
```


# Case example Raw Data Table 

## Data Preparation


There are 2 raw data available on the Github website, including "POC" file and "PhillyCrimeSince2015" file. For "POC" file, we  will select random sample of 500 elements in a subset of the data set. In addition, "PhillyCrimeSince2015" file will only select crime cases in 2023. Moreover, if the latitude and longitude of the subdataset are missing, the observation will be excluded.




```{r}

# read final file
POC = read.csv("https://raw.githubusercontent.com/GUANTSERN-KUO/webcv/main/w07/POC.csv")

```

```{r}
set.seed(123458)
#select random sample of 500 elements with NO replacement
kept_samp <- sample(1:nrow(POC), size = 500, replace = FALSE)

#select random sample of 500 rows from data frame
rand500_POC <- POC[kept_samp, ]


```


```{r}
# write final data to csv file
write.csv(x = rand500_POC, file = "rand500_POC.csv", row.names = FALSE)
```


```{r}
# read final file
Philly = read.csv("https://raw.githubusercontent.com/GUANTSERN-KUO/webcv/main/w07/PhillyCrimeSince2015.csv")
Philly$year <- year(as.POSIXct(Philly$date, format = "%m/%d/%Y %H:%M", tz = "EST") )


Philly2023 <- filter(Philly,year==2023)  # create 2023data

Philly2023 <- filter(Philly2023,!is.na(lat)) # remove missing obs



Philly2023$ageColor<-gsub("Fatal","orange",as.character(Philly2023$fatal))

Philly2023$ageColor<-gsub("Nonfatal","darkred",as.character(Philly2023$ageColor))

```

```{r}

PhDT <- Philly2023 %>%
  dplyr::select(race, age,lng,lat,year)

POCDT <- rand500_POC %>%
  dplyr::select(STATE ,county,ADDRESS,ZIPnew,diesel,dist.to.poc,ycoord,xcoord)
```


## Descriptive Study Purpose & Variables Relationship 

The study primary focus on the distribution of diesel used in gas station. Secondary understanding of the Mean distance between a gas station and the Point of Compromised in PA. Finally, We want to understand crime map in PA.




The below is the sub-data table for "PhillyCrimeSince2015". However, we will only use 5 variables and display data table as below.


- lng : longitude
- lat : latitude



```{r eval=requireNamespace("DT", quietly=TRUE), echo=FALSE}
DT::datatable((PhDT), fillContainer = FALSE, options = list(pageLength = 6 )  )

```
The average age of offenders was 30.98, with the lowest age of offenders being 2.

```{r}
summary(PhDT$age)

```








The below is the sub-data table for "POC". However, we will only use 8 variables and display data table as below.


- xcoord : longitude
- ycoord : latitude
- dist.to.poc : distance between a gas station and the nearest POC
```{r eval=requireNamespace("DT", quietly=TRUE), echo=FALSE}
DT::datatable((POCDT), fillContainer = FALSE, options = list(pageLength = 6 )  )

```

The average distance was 17.6, with the lowest distance being 0.12 and maximum distance being 47.7.


```{r}
summary(POCDT$dist.to.poc)

```



##   Distribution of diesel used in gas station across U.S.

500 gas stations across U.S have been randomly selected from POC data. 294 gas stations provide Diesel service, that is 58.8 percent of selected gas stations. While 206 gas stations (41.2 percent) do not have Diesel service.


```{r}
piedata <- filter(rand500_POC,!is.na(diesel))

piedataf = data.frame(cate =as.vector(unique(piedata$diesel)), 
                     freq = as.vector(table(piedata$diesel)))

## remove string X
piedataf$cate<-gsub("Y","Yes",as.character(piedataf$cate))
piedataf$cate<-gsub("N","No",as.character(piedataf$cate))


# define a color vector
colors <- c('rgb(211,94,96)', 'rgb(128,133,133)', 'rgb(144,103,167)')
# make a pie chart
plot_ly(piedataf, 
        labels = ~cate, 
        values = ~freq, 
        type = 'pie',
        textposition = 'inside',
        textinfo = 'label + percent',
        insidetextfont = list(color = '#FFFFFF'),
        #hoverinfo = 'text',
        marker = list(colors = colors,
                      line = list(color = '#FFFFFF', width = 1)),
                      #The 'pull' attribute can also be used to create space between the sectors
        showlegend = TRUE) %>% 
         layout(title = 'Distribution of diesel used in gas station',
                xaxis = list(showgrid = FALSE, zeroline = FALSE, 
                             showticklabels = FALSE),
                yaxis = list(showgrid = FALSE, zeroline = FALSE, 
                             showticklabels = FALSE),
                      ## margin of the plot
      margin = list(
              b = 50,
              l = 100,
              t = 120,
              r = 50
      ))


``` 


##   The diesel service of gas stations throughout the U.S

Looking at a the entire U.S. map, the supply of diesel fuel stations in each region is fairly normal regardless east region, west region, and central region. It is convenience for people to find diesel fuel stations as there are plenty of gas stations within each county and within short distance.


```{r}


label.msg <- paste(paste("DIESEL:",rand500_POC$diesel),"\n")
                 



# making static leaflet map
map0 <- leaflet(rand500_POC) %>%
  addTiles() %>% 
  setView(lng=mean(rand500_POC$xcoord), lat=mean(rand500_POC$ycoord), zoom = 14) %>%
   addRectangles(
    lng1 = min(rand500_POC$xcoord), lat1 = min(rand500_POC$ycoord),
    lng2 = max(rand500_POC$xcoord), lat2 = max(rand500_POC$ycoord),
    #fillOpacity = 0.2,
    fillColor = "transparent" 
    ) %>%
  fitBounds(
    lng1 = min(rand500_POC$xcoord), lat1 = min(rand500_POC$ycoord),
    lng2 = max(rand500_POC$xcoord), lat2 = max(rand500_POC$ycoord) ) %>%
  addMarkers(~xcoord, ~ycoord, label = ~label.msg,
         
             popup = ~paste(label.msg, 
                            "<br>state:", STATE, 
                            "<br>county:", county, 
                            "<br>address", ADDRESS,
                            "<br>zip code", ZIPnew)
             
              )

title <- tags$div( HTML('<font color = "darkred" size =4><b>Do gas stations have diesel service throughout the U.S.?</b></font>')
)
 title2 <- tags$div( HTML('<font color = "red" size =0.5><b>500 randomly selected gas stations from the entire gas station dataset</b></font>')
)
###
map0 <- map0 %>%
     addControl(title, position = "topright")

map0 <- map0 %>%
     addControl(title2, position = "topright")

      
   

 map0

```

##   The Mean distance between a gas station and the Point of Compromised in PA 2023

Berks county has the highest mean distance (36.52) between a gas station and the Point of Compromised. Lehigh county has the lowest mean distance (7.27). The mean difference (29.25) between these two counties is pretty high.

```{r}

PA_POC <- filter(rand500_POC,STATE == "PA")  # create 2015data


# Specify data frame
group_mean <- PA_POC %>%
    # Specify group indicator, column, function
    group_by(county) %>%
    # Calculate the mean of the "Frequency" column for each group
    summarise_at(vars(dist.to.poc),
                 list(Mean_Frequency = mean))
 
plot_ly(
    data = group_mean,
    x = ~county,  # Horizontal axis 
    y = ~Mean_Frequency,   # Vertical axis 
    color = ~factor(county),  # must be a numeric factor
    #text = ~Species,
  
     # Show the species in the hover text
     ## using the following hovertemplate() to add the information of the
     ## Two numerical variables to the hover text.
     ### Use the following hover template to display more information
    
     alpha  = 0.6,
   
     type = "scatter",
     mode = "markers",
     ## graphic size
     width = 700,
     height = 500

)%>%
    layout(  
      ### Title 
      title =list(text = "Mean distance between a gas station and the nearest POC in PA 2023", 
                  font = list(family = "Times New Roman",  # HTML font family  
                                size = 18,
                               color = "red")), 
      ### legend
      legend = list(title = list(text = 'county',
                                 font = list(family = "Courier New",
                                               size = 14,
                                              color = "green")),
                    bgcolor = "ivory",
                    bordercolor = "navy",
                    groupclick = "togglegroup",  # one of  "toggleitem" AND "togglegroup".
                    orientation = "v"  # Sets the orientation of the legend.
                    ),
      ## margin of the plot
      margin = list(
              b = 100,
              l = 100,
              t = 100,
              r = 50
      ),
      ## Background
      plot_bgcolor ='#f7f7f7', 
      ## Axes labels
             xaxis = list( 
                    title=list(text = 'County',
                               font = list(family = 'Arial')),
                    zerolinecolor = 'red', 
                    zerolinewidth = 2, 
                    gridcolor = 'white'), 
            yaxis = list( 
                    title=list(text = 'Mean distance',
                               font = list(family = 'Arial')),
                    zerolinecolor = 'purple', 
                    zerolinewidth = 2, 
                    gridcolor = 'white')

)

```






##   Crime Map in PA 2023

Below crime map is showing the offenders in PA state in year 2023. The amount of Non-fatal cases are higher than the amount of Fatal cases. 


```{r}

ageColor <- Philly2023$ageColor


label.msg <- paste(paste("Race:", Philly2023$race),    
                   paste("\n Age:",Philly2023$age),"\n")

#labels = cat(label.msg)
# making leaflet map
#labels = cat(label.msg)
# making leaflet map

# making leaflet map
 map <- leaflet(Philly2023) %>%
  addTiles() %>% 
  setView(lng=mean(Philly2023$lng), lat=mean(Philly2023$lat), zoom = 15) %>%
  #OpenStreetMap, Stamen, Esri and OpenWeatherMap.
  #addProviderTiles("Esri.WorldGrayCanvas") %>%
  addProviderTiles(providers$Esri.WorldGrayCanvas) %>%
  addCircleMarkers(
            ~lng, 
            ~lat,
            color = ageColor,
            radius = ~ (Philly2023$age/10),
            stroke = FALSE, 
            fillOpacity = 0.4,
            label = ~label.msg)  %>%
  addLegend(position = "bottomright", 
            colors = c("orange","darkred"),
            labels= c( "Fatal", "Nonfatal"),
            title= "Crime Category",
            opacity = 0.4) 
 
 
 
 
 title <- tags$div( HTML('<font color = "darkred" size =4><b>Pennsylvania crime map in 2023 </b></font>')
)
 title2 <- tags$div( HTML('<font color = "red" size =0.5><b>The point size is proportional to the age of the criminal </b></font>')
)
###
EnhancedMap <- map %>%
     addControl(title, position = "topright")

EnhancedMap <- EnhancedMap %>%
     addControl(title2, position = "topright")

      
   

 EnhancedMap
```












